:doctype: book
:icons: font
:source-highlighter: highlightjs
:toc: macro
:toclevels: 1
:sectlinks:
:linkattrs:

[[targets]]
= Targets

toc::[]


== GET /rest/v1/targets 

=== Implementation notes

Handles the GET request of retrieving all targets within Hawkbit. Required permission: READ_TARGET

=== Get paged list of targets

==== CURL

include::{snippets}/targets/get-targets/curl-request.adoc[]

==== Request URL

A `GET` request is used to access the targets

include::{snippets}/targets/get-targets/http-request.adoc[]

==== Request query parameter

include::{snippets}/targets/get-targets-with-parameters/request-parameters.adoc[]

==== Request parameter example

include::{snippets}/targets/get-targets-with-parameters/http-request.adoc[]

=== Response (Status 200)

==== Response fields 

include::{snippets}/targets/get-targets/response-fields.adoc[]

==== Response example 

include::{snippets}/targets/get-targets/http-response.adoc[]

=== Error responses

|===
| HTTP Status Code | Reason | Response Model

include::../errors/400.adoc[]
include::../errors/401.adoc[]
include::../errors/403.adoc[]
include::../errors/405.adoc[]
include::../errors/406.adoc[]
include::../errors/429.adoc[]
|===


== POST /rest/v1/targets 

=== Implementation Notes

Handles the POST request of creating new targets within Hawkbit. The request body must always be a list of targets. Required Permission: CREATE_TARGET

=== Create list of targets 

==== CURL

include::{snippets}/targets/post-targets/curl-request.adoc[]

==== Request URL

include::{snippets}/targets/post-targets/http-request.adoc[]

==== Request fields

include::{snippets}/targets/post-targets/request-fields.adoc[]

=== Response (Status 201)

==== Response fields 

include::{snippets}/targets/post-targets/response-fields.adoc[]

==== Response example

include::{snippets}/targets/post-targets/http-response.adoc[]

=== Error responses

|===
| HTTP Status Code | Reason | Response Model

include::../errors/400.adoc[]
include::../errors/401.adoc[]
include::../errors/403_quota.adoc[]
include::../errors/405.adoc[]
include::../errors/406.adoc[]
include::../errors/409.adoc[]
include::../errors/415.adoc[]
include::../errors/429.adoc[]
|===


== DELETE /rest/v1/targets/{targetId} 

=== Implementation Notes

Handles the DELETE request of deleting a single target within Hawkbit. Required Permission: DELETE_TARGET

=== Deleting a target

==== CURL

include::{snippets}/targets/delete-target/curl-request.adoc[]

==== Request URL

include::{snippets}/targets/delete-target/http-request.adoc[]

==== Request path parameter

include::{snippets}/targets/delete-target/path-parameters.adoc[]

=== Response (Status 200)

==== Response example

include::{snippets}/targets/delete-target/http-response.adoc[]

=== Error responses

|===
| HTTP Status Code | Reason | Response Model

include::../errors/400.adoc[]
include::../errors/401.adoc[]
include::../errors/403.adoc[]
include::../errors/404.adoc[]
include::../errors/405.adoc[]
include::../errors/406.adoc[]
include::../errors/429.adoc[]
|===


== GET /rest/v1/targets/{targetId}

=== Implementation Notes

Handles the GET request of retrieving a single target within Hawkbit. Required Permission: READ_TARGET

=== Get single target

==== CURL

include::{snippets}/targets/get-target/curl-request.adoc[]

==== Request URL

include::{snippets}/targets/get-target/http-request.adoc[]

==== Request path parameter

include::{snippets}/targets/get-target/path-parameters.adoc[]

=== Response (Status 200)

==== Response fields

include::{snippets}/targets/get-target/response-fields.adoc[]

==== Response example

include::{snippets}/targets/get-target/http-response.adoc[]

=== Error responses

|===
| HTTP Status Code | Reason | Response Model

include::../errors/400.adoc[]
include::../errors/401.adoc[]
include::../errors/403.adoc[]
include::../errors/404.adoc[]
include::../errors/405.adoc[]
include::../errors/406.adoc[]
include::../errors/429.adoc[]
|===


== PUT /rest/v1/targets/{targetId}

=== Implementation Notes

Handles the PUT request of updating a target within Hawkbit. Required Permission: UPDATE_TARGET

=== Update a target

==== Curl

include::{snippets}/targets/put-target/curl-request.adoc[]

==== Request URL

include::{snippets}/targets/put-target/http-request.adoc[]

==== Request path parameter

include::{snippets}/targets/put-target/path-parameters.adoc[]

==== Request fields

include::{snippets}/targets/put-target/request-fields.adoc[]

=== Response (Status 200)

==== Response fields

include::{snippets}/targets/put-target/response-fields.adoc[]

==== Response example

include::{snippets}/targets/put-target/http-response.adoc[]

=== Error responses

|===
| HTTP Status Code | Reason | Response Model

include::../errors/400.adoc[]
include::../errors/401.adoc[]
include::../errors/403.adoc[]
include::../errors/404.adoc[]
include::../errors/405.adoc[]
include::../errors/406.adoc[]
include::../errors/409.adoc[]
include::../errors/415.adoc[]
include::../errors/429.adoc[]
|===


== GET /rest/v1/targets/{targetId}/autoConfirm

=== Implementation Notes

Handles the GET request to check the current auto-confirmation state of a target. Required Permission: READ_TARGET

=== Request auto-confirmation state for a specific target

==== Curl

include::{snippets}/targets/get-target-auto-confirm-state-active/curl-request.adoc[]

==== Request URL

include::{snippets}/targets/get-target-auto-confirm-state-active/http-request.adoc[]

==== Request path parameter

include::{snippets}/targets/get-target-auto-confirm-state-active/path-parameters.adoc[]

=== Response in case auto-confirmation is active (Status 200)

In case auto-confirmation is active, details like the initiator, remark and date of activation (as unix timestamp) will be provided. Reference links to switch the auto-confirmation state are exposed as well.

==== Response fields

include::{snippets}/targets/get-target-auto-confirm-state-active/response-fields.adoc[]

==== Response example

include::{snippets}/targets/get-target-auto-confirm-state-active/http-response.adoc[]

=== Response in case auto-confirmation is not active (Status 200)

The response body references a link to activate auto-confirmation.

==== Response fields

include::{snippets}/targets/get-target-auto-confirm-state-not-active/response-fields.adoc[]

==== Response example

include::{snippets}/targets/get-target-auto-confirm-state-not-active/http-response.adoc[]

=== Error responses

|===
| HTTP Status Code | Reason | Response Model

include::../errors/400.adoc[]
include::../errors/401.adoc[]
include::../errors/403.adoc[]
include::../errors/404.adoc[]
include::../errors/405.adoc[]
include::../errors/406.adoc[]
include::../errors/429.adoc[]
|===


== POST /rest/v1/targets/{targetId}/autoConfirm/activate

=== Implementation Notes

Handles the POST request to activate auto-confirmation for a specific target.
As a result all current active as well as future actions will automatically be confirmed by mentioning the initiator as triggered person.
Actions will be automatically confirmed, as long as auto-confirmation is active.
Required Permission: UPDATE_TARGET

=== Activate auto-confirmation for a target

==== Curl

include::{snippets}/targets/post-activate-auto-confirm/curl-request.adoc[]

==== Request URL

include::{snippets}/targets/post-activate-auto-confirm/http-request.adoc[]

==== Request path parameter

include::{snippets}/targets/post-activate-auto-confirm/path-parameters.adoc[]

==== Request fields

include::{snippets}/targets/post-activate-auto-confirm/request-fields.adoc[]

=== Response (Status 200)

=== Error responses

|===
| HTTP Status Code | Reason | Response Model

include::../errors/400.adoc[]
include::../errors/401.adoc[]
include::../errors/403.adoc[]
include::../errors/404.adoc[]
include::../errors/405.adoc[]
include::../errors/406.adoc[]
include::../errors/409.adoc[]
include::../errors/415.adoc[]
include::../errors/429.adoc[]
|===


== POST /rest/v1/targets/{targetId}/autoConfirm/deactivate

=== Implementation Notes

Handles the POST request to deactivate auto-confirmation for a specific target.
All active actions will remain unchanged while all future actions need to be confirmed, before processing with the deployment.
Required Permission: UPDATE_TARGET

=== Deactivate auto-confirmation for a target

==== Curl

include::{snippets}/targets/post-deactivate-auto-confirm/curl-request.adoc[]

==== Request URL

include::{snippets}/targets/post-deactivate-auto-confirm/http-request.adoc[]

==== Request path parameter

include::{snippets}/targets/post-deactivate-auto-confirm/path-parameters.adoc[]

=== Response (Status 200)

=== Error responses

|===
| HTTP Status Code | Reason | Response Model

include::../errors/400.adoc[]
include::../errors/401.adoc[]
include::../errors/403.adoc[]
include::../errors/404.adoc[]
include::../errors/405.adoc[]
include::../errors/406.adoc[]
include::../errors/409.adoc[]
include::../errors/415.adoc[]
include::../errors/429.adoc[]
|===


== GET /rest/v1/targets/{targetId}/actions

=== Implementation Notes

Handles the GET request of retrieving the full action history of a specific target. Required Permission: READ_TARGET

=== List all actions of Target

==== Curl

include::{snippets}/targets/get-actions-from-target/curl-request.adoc[]

==== Request URL

include::{snippets}/targets/get-actions-from-target/http-request.adoc[]

==== Request path parameter

include::{snippets}/targets/get-actions-from-target/path-parameters.adoc[]

==== Request query parameter

include::{snippets}/targets/get-actions-from-target-with-parameters/request-parameters.adoc[]

==== Request parameter example

include::{snippets}/targets/get-actions-from-target-with-parameters/http-request.adoc[]

=== Response (Status 200)

==== Response fields

include::{snippets}/targets/get-actions-from-target-with-maintenance-window/response-fields.adoc[]

==== Response example

include::{snippets}/targets/get-actions-from-target/http-response.adoc[]

==== Response example with Maintenance Window

include::{snippets}/targets/get-actions-from-target-with-maintenance-window/http-response.adoc[]

=== Error responses

|===
| HTTP Status Code | Reason | Response Model

include::../errors/400.adoc[]
include::../errors/401.adoc[]
include::../errors/403.adoc[]
include::../errors/405.adoc[]
include::../errors/406.adoc[]
include::../errors/429.adoc[]
|===


== PUT /rest/v1/targets/{targetId}/actions/{actionId}

=== Implementation Notes

Handles the PUT request to switch an action from soft to forced. Required Permission: UPDATE_TARGET.

=== Update a target

==== Curl

include::{snippets}/targets/switch-action-to-forced/curl-request.adoc[]

==== Request URL

include::{snippets}/targets/switch-action-to-forced/http-request.adoc[]

==== Request path parameter

include::{snippets}/targets/switch-action-to-forced/path-parameters.adoc[]

==== Request fields

include::{snippets}/targets/switch-action-to-forced/request-fields.adoc[]

=== Response (Status 200)

==== Response fields

include::{snippets}/targets/switch-action-to-forced/response-fields.adoc[]

==== Response example

include::{snippets}/targets/switch-action-to-forced/http-response.adoc[]

=== Error responses

|===
| HTTP Status Code | Reason | Response Model

include::../errors/400.adoc[]
include::../errors/401.adoc[]
include::../errors/403.adoc[]
include::../errors/404.adoc[]
include::../errors/405.adoc[]
include::../errors/406.adoc[]
include::../errors/409.adoc[]
include::../errors/415.adoc[]
include::../errors/429.adoc[]
|===

== DELETE /rest/v1/targets/{targetId}/actions/{actionId}

=== Implementation Notes

Cancels an active action, only active actions can be deleted. Required Permission: UPDATE_TARGET

=== Canceling an active action

==== Curl

include::{snippets}/targets/delete-action-from-target/curl-request.adoc[]

==== Request URL

include::{snippets}/targets/delete-action-from-target/http-request.adoc[]

==== Request path parameter

include::{snippets}/targets/delete-action-from-target/path-parameters.adoc[]

==== Request query parameter

include::{snippets}/targets/delete-action-from-target-with-parameters/request-parameters.adoc[]

==== Request parameter example

include::{snippets}/targets/delete-action-from-target-with-parameters/http-request.adoc[]

=== Response (Status 204)

==== Response example

include::{snippets}/targets/delete-action-from-target/http-response.adoc[]

=== Error responses

|===
| HTTP Status Code | Reason | Response Model

include::../errors/400.adoc[]
include::../errors/401.adoc[]
include::../errors/403.adoc[]
include::../errors/404.adoc[]
include::../errors/405.adoc[]
include::../errors/406.adoc[]
include::../errors/429.adoc[]
|===


== GET /rest/v1/targets/{targetId}/actions/{actionId}

=== Implementation Notes

Handles the GET request of retrieving a specific action on a specific target. Required Permission: READ_TARGET

=== Get assigned action of target

==== Curl

include::{snippets}/targets/get-action-from-target/curl-request.adoc[]

==== Request URL

include::{snippets}/targets/get-action-from-target/http-request.adoc[]

==== Request path parameter

include::{snippets}/targets/get-action-from-target/path-parameters.adoc[]

=== Response (Status 200)

==== Response fields 

include::{snippets}/targets/get-action-from-target-with-maintenance-window/response-fields.adoc[]

==== Response example

include::{snippets}/targets/get-action-from-target/http-response.adoc[]

==== Response example with Maintenance Window

include::{snippets}/targets/get-action-from-target-with-maintenance-window/http-response.adoc[]

=== Error responses

|===
| HTTP Status Code | Reason | Response Model

include::../errors/400.adoc[]
include::../errors/401.adoc[]
include::../errors/403.adoc[]
include::../errors/404.adoc[]
include::../errors/405.adoc[]
include::../errors/406.adoc[]
include::../errors/429.adoc[]
|===


== GET /rest/v1/targets/{targetId}/actions/{actionId}/status

=== Implementation Notes

Handles the GET request of retrieving a specific action on a specific target. Required Permission: READ_TARGET

=== Get statuses of  assigned action

==== Curl

include::{snippets}/targets/get-status-from-action/curl-request.adoc[]

==== Request URL

include::{snippets}/targets/get-status-from-action/http-request.adoc[]

==== Request path parameter

include::{snippets}/targets/get-status-from-action/path-parameters.adoc[]

==== Request parameter

include::{snippets}/targets/get-status-from-action-with-parameters/request-parameters.adoc[]

==== Request parameter example

include::{snippets}/targets/get-status-from-action-with-parameters/http-request.adoc[]

=== Response (Status 200)

==== Response fields 

include::{snippets}/targets/get-status-from-action/response-fields.adoc[]

==== Response example

include::{snippets}/targets/get-status-from-action/http-response.adoc[]

=== Error responses

|===
| HTTP Status Code | Reason | Response Model

include::../errors/400.adoc[]
include::../errors/401.adoc[]
include::../errors/403.adoc[]
include::../errors/404.adoc[]
include::../errors/405.adoc[]
include::../errors/406.adoc[]
include::../errors/429.adoc[]
|===


== GET /rest/v1/targets/{targetId}/assignedDS

=== Implementation Notes

Handles the GET request of retrieving the assigned distribution set of an specific target. Required Permission: READ_TARGET

=== Get assigned distribution set of target

==== Curl

include::{snippets}/targets/get-assigned-distribution-set-from-action/curl-request.adoc[]

==== Request URL

include::{snippets}/targets/get-assigned-distribution-set-from-action/http-request.adoc[]

==== Request path parameter

include::{snippets}/targets/get-assigned-distribution-set-from-action/path-parameters.adoc[]

=== Response (Status 200)

==== Response fields 

include::{snippets}/targets/get-assigned-distribution-set-from-action/response-fields.adoc[]

==== Response example

include::{snippets}/targets/get-assigned-distribution-set-from-action/http-response.adoc[]

=== Error responses

|===
| HTTP Status Code | Reason | Response Model

include::../errors/400.adoc[]
include::../errors/401.adoc[]
include::../errors/403.adoc[]
include::../errors/404.adoc[]
include::../errors/405.adoc[]
include::../errors/406.adoc[]
include::../errors/429.adoc[]
|===


== POST /rest/v1/targets/{targetId}/assignedDS (assign single distribution set)

=== Implementation Notes

Handles the POST request for assigning a distribution set to a specific target. Required Permission: READ_REPOSITORY and UPDATE_TARGET

=== Assign distribution set to target

==== Curl

include::{snippets}/targets/post-assign-distribution-set-to-target/curl-request.adoc[]

==== Request path parameter

include::{snippets}/targets/post-assign-distribution-set-to-target/path-parameters.adoc[]

==== Request query parameter

include::{snippets}/targets/post-assign-distribution-set-to-target/request-parameters.adoc[]

==== Request fields

include::{snippets}/targets/post-assign-distribution-set-to-target/request-fields.adoc[]

==== Request URL

include::{snippets}/targets/post-assign-distribution-set-to-target/http-request.adoc[]

=== Response (Status 200)

==== Response fields
include::{snippets}/targets/post-assign-distribution-set-to-target/response-fields.adoc[]

==== Response example 

include::{snippets}/targets/post-assign-distribution-set-to-target/http-response.adoc[]

=== Error responses

|===
| HTTP Status Code | Reason | Response Model

include::../errors/400.adoc[]
include::../errors/401.adoc[]
include::../errors/403.adoc[]
include::../errors/404.adoc[]
include::../errors/405.adoc[]
include::../errors/406.adoc[]
include::../errors/409.adoc[]
include::../errors/415.adoc[]
include::../errors/429.adoc[]
|===


== POST /rest/v1/targets/{targetId}/assignedDS (assign multiple distribution sets)

=== Implementation Notes

Handles the POST request for assigning multiple distribution sets to a specific target (only allowed id 'multi assignments' is enabled). Required Permission: READ_REPOSITORY and UPDATE_TARGET

=== Assign distribution sets to target

==== Curl

include::{snippets}/targets/post-assign-distribution-sets-to-target/curl-request.adoc[]

==== Request path parameter

include::{snippets}/targets/post-assign-distribution-sets-to-target/path-parameters.adoc[]

==== Request query parameter

include::{snippets}/targets/post-assign-distribution-sets-to-target/request-parameters.adoc[]

==== Request fields

include::{snippets}/targets/post-assign-distribution-sets-to-target/request-fields.adoc[]

==== Request URL

include::{snippets}/targets/post-assign-distribution-sets-to-target/http-request.adoc[]

=== Response (Status 200)

==== Response fields
include::{snippets}/targets/post-assign-distribution-sets-to-target/response-fields.adoc[]

==== Response example 

include::{snippets}/targets/post-assign-distribution-sets-to-target/http-response.adoc[]

=== Error responses

|===
| HTTP Status Code | Reason | Response Model

include::../errors/400_multiassignment.adoc[]
include::../errors/401.adoc[]
include::../errors/403.adoc[]
include::../errors/404.adoc[]
include::../errors/405.adoc[]
include::../errors/406.adoc[]
include::../errors/409.adoc[]
include::../errors/415.adoc[]
include::../errors/429.adoc[]
|===


== GET /rest/v1/targets/{targetId}/attributes

=== Implementation Notes

Handles the GET request of retrieving the attributes of a specific target. Reponse is a key/value list. Required Permission: READ_TARGET

=== Get attributes of target

==== Curl

include::{snippets}/targets/get-controller-attributes/curl-request.adoc[]

==== Request URL

include::{snippets}/targets/get-controller-attributes/http-request.adoc[]

==== Request path parameter

include::{snippets}/targets/get-controller-attributes/path-parameters.adoc[]

=== Response (Status 200)

==== Response example

include::{snippets}/targets/get-controller-attributes/http-response.adoc[]

=== Error responses

|===
| HTTP Status Code | Reason | Response Model

include::../errors/400.adoc[]
include::../errors/401.adoc[]
include::../errors/403.adoc[]
include::../errors/404.adoc[]
include::../errors/405.adoc[]
include::../errors/406.adoc[]
include::../errors/429.adoc[]
|===


== GET /rest/v1/targets/{targetId}/installedDS 

=== Implementation Notes

Handles the GET request of retrieving the installed distribution set of an specific target. Required Permission: READ_TARGET

=== Get installed distribution set of target

==== Curl

include::{snippets}/targets/get-installed-distribution-set-from-target/curl-request.adoc[]

==== Request URL

include::{snippets}/targets/get-installed-distribution-set-from-target/http-request.adoc[]

==== Request path parameter

include::{snippets}/targets/get-installed-distribution-set-from-target/path-parameters.adoc[]

=== Response (Status 200)

==== Response fields 

include::{snippets}/targets/get-installed-distribution-set-from-target/response-fields.adoc[]

==== Response example

include::{snippets}/targets/get-installed-distribution-set-from-target/http-response.adoc[]

=== Error responses

|===
| HTTP Status Code | Reason | Response Model

include::../errors/400.adoc[]
include::../errors/401.adoc[]
include::../errors/403.adoc[]
include::../errors/404.adoc[]
include::../errors/405.adoc[]
include::../errors/406.adoc[]
include::../errors/429.adoc[]
|===

== GET /rest/v1/targets/{targetId}/metadata

===  Implementation Notes

Get a paged list of meta data for a target. Required permission: READ_REPOSITORY

=== Get a paged list of meta data

==== Curl

include::{snippets}/targets/get-metadata/curl-request.adoc[]

==== Request URL

include::{snippets}/targets/get-metadata/http-request.adoc[]

==== Request path parameter

include::{snippets}/targets/get-metadata/path-parameters.adoc[]

==== Request query parameter

include::{snippets}/targets/get-metadata-with-parameters/request-parameters.adoc[]

==== Request parameter example

include::{snippets}/targets/get-metadata-with-parameters/http-request.adoc[]

=== Response (Status 200)

==== Response fields

include::{snippets}/targets/get-metadata/response-fields.adoc[]

==== Response example

include::{snippets}/targets/get-metadata/http-response.adoc[]

=== Error responses

|===
| HTTP Status Code | Reason | Response Model

include::../errors/400.adoc[]
include::../errors/401.adoc[]
include::../errors/403.adoc[]
include::../errors/405.adoc[]
include::../errors/406.adoc[]
include::../errors/429.adoc[]
|===

== POST /rest/v1/targets/{targetId}/metadata

=== Implementation Notes

Create a list of meta data entries Required permissions: READ_REPOSITORY and UPDATE_TARGET

=== Create a list of meta data entries


==== CURL

include::{snippets}/targets/create-metadata/curl-request.adoc[]

==== Request URL

include::{snippets}/targets/create-metadata/http-request.adoc[]

==== Request path parameter

include::{snippets}/targets/create-metadata/path-parameters.adoc[]

==== Request fields

include::{snippets}/targets/create-metadata/request-fields.adoc[]

=== Response (Status 200)

==== Response example

include::{snippets}/targets/create-metadata/http-response.adoc[]

=== Error responses

|===
| HTTP Status Code | Reason | Response Model

include::../errors/400.adoc[]
include::../errors/401.adoc[]
include::../errors/403.adoc[]
include::../errors/404.adoc[]
include::../errors/405.adoc[]
include::../errors/406.adoc[]
include::../errors/409.adoc[]
include::../errors/415.adoc[]
include::../errors/429.adoc[]
|===


== DELETE /rest/v1/targets/{targetId}/metadata/{metadataKey}


=== Implementation Notes

Delete a single meta data. Required permission: UPDATE_REPOSITORY

=== Delete a single meta data

==== CURL

include::{snippets}/targets/delete-metadata/curl-request.adoc[]

==== Request URL

include::{snippets}/targets/delete-metadata/http-request.adoc[]

==== Request path parameter

include::{snippets}/targets/delete-metadata/path-parameters.adoc[]

=== Response (Status 200)

==== Response example

include::{snippets}/targets/delete-metadata/http-response.adoc[]

=== Error responses

|===
| HTTP Status Code | Reason | Response Model

include::../errors/400.adoc[]
include::../errors/401.adoc[]
include::../errors/403.adoc[]
include::../errors/404.adoc[]
include::../errors/405.adoc[]
include::../errors/406.adoc[]
include::../errors/429.adoc[]
|===


== GET /rest/v1/targets/{targetId}/metadata/{metadataKey}


===  Implementation Notes

Get a single meta data value for a meta data key. Required permission: READ_REPOSITORY

=== Get a single meta data value

==== Curl

include::{snippets}/targets/get-metadata-value/curl-request.adoc[]

==== Request URL

include::{snippets}/targets/get-metadata-value/http-request.adoc[]

==== Request path parameter

include::{snippets}/targets/get-metadata-value/path-parameters.adoc[]

=== Response (Status 200)

==== Response fields

include::{snippets}/targets/get-metadata-value/response-fields.adoc[]

==== Response example

include::{snippets}/targets/get-metadata-value/http-response.adoc[]

=== Error responses

|===
| HTTP Status Code | Reason | Response Model

include::../errors/400.adoc[]
include::../errors/401.adoc[]
include::../errors/403.adoc[]
include::../errors/405.adoc[]
include::../errors/406.adoc[]
include::../errors/429.adoc[]
|===

== PUT /rest/v1/targets/{targetId}/metadata/{metadataKey} 


=== Implementation Notes

Update a single meta data value for speficic key. Required permission: UPDATE_REPOSITORY

=== Update a single meta data value

==== Curl

include::{snippets}/targets/update-metadata/curl-request.adoc[]

==== Request URL

include::{snippets}/targets/update-metadata/http-request.adoc[]

==== Request path parameter

include::{snippets}/targets/update-metadata/path-parameters.adoc[]

==== Request fields

include::{snippets}/targets/update-metadata/request-fields.adoc[]

=== Response (Status 200)

==== Response fields

include::{snippets}/targets/update-metadata/response-fields.adoc[]

==== Response example

include::{snippets}/targets/update-metadata/http-response.adoc[]

=== Error responses

|===
| HTTP Status Code | Reason | Response Model

include::../errors/400.adoc[]
include::../errors/401.adoc[]
include::../errors/403.adoc[]
include::../errors/404.adoc[]
include::../errors/405.adoc[]
include::../errors/406.adoc[]
include::../errors/409.adoc[]
include::../errors/415.adoc[]
include::../errors/429.adoc[]
|===

== POST /rest/v1/targets/{targetId}/targettype

===  Implementation Notes

Assign or update the target type of a target. Required permission: UPDATE_TARGET

=== Assign a target type to a target

==== Curl

include::{snippets}/targets/post-assign-target-type/curl-request.adoc[]

==== Request URL

include::{snippets}/targets/post-assign-target-type/http-request.adoc[]

==== Request path parameter

include::{snippets}/targets/post-assign-target-type/path-parameters.adoc[]

==== Request fields

include::{snippets}/targets/post-assign-target-type/request-fields.adoc[]

=== Response (Status 200)

==== Response example

include::{snippets}/targets/post-assign-target-type/http-response.adoc[]

=== Error responses

|===
| HTTP Status Code | Reason | Response Model

include::../errors/400.adoc[]
include::../errors/401.adoc[]
include::../errors/403.adoc[]
include::../errors/405.adoc[]
include::../errors/429.adoc[]
|===

== DELETE /rest/v1/targets/{targetId}/targettype

===  Implementation Notes

Remove the target type from a target. The target type will be set to null. Required permission: UPDATE_TARGET

=== Remove a target type from a target

==== Curl

include::{snippets}/targets/delete-unassign-target-type/curl-request.adoc[]

==== Request URL

include::{snippets}/targets/delete-unassign-target-type/http-request.adoc[]

==== Request path parameter

include::{snippets}/targets/delete-unassign-target-type/path-parameters.adoc[]

=== Response (Status 200)

==== Response example

include::{snippets}/targets/delete-unassign-target-type/http-response.adoc[]

=== Error responses

|===
| HTTP Status Code | Reason | Response Model

include::../errors/400.adoc[]
include::../errors/401.adoc[]
include::../errors/403.adoc[]
include::../errors/405.adoc[]
include::../errors/429.adoc[]
|===

== Additional content

[[error-body]]
=== Error body

include::../errors/error-response-body.adoc[]


